package com.qining618.cms.ucenter.mapper;

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.qining618.cms.ucenter.domain.Menu;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import org.springframework.stereotype.Repository;

import java.util.List;
import java.util.Map;

/**
 * <p>
 * 菜单 Mapper 接口
 * </p>
 *
 * @author qining
 * @date 2019-09-16
 */
@Mapper
@Repository
public interface MenuMapper extends BaseMapper<Menu> {

    /**
     * 分页查询
     * @param page 分页信息
     * @param params 参数
     * @return IPage
     */
    IPage<Menu> page(Page<Menu> page, @Param("map") Map<String, Object> params);

    /**
     * 标号是否已经存在
     * @param code 编号
     * @return boolean
     */
    @Select("select count(1) from o_menu where code = #{code}")
    boolean existByCode(@Param("code") String code);

    /**
     * 获取下级菜单id列表
     * @param parentId 上级id
     * @return List&lt;Long&gt;
     */
    @Select("select id from o_menu where parent_id = #{parentId}")
    List<Long> getChildIds(@Param("parentId") Long parentId);

}
